import React from "react";
import { Button, Checkbox, Form, Input, message as antdMessage } from "antd";
import { http } from "../../utils/http";
import { useNavigate } from "react-router-dom";


const onFinishFailed = (errorInfo: any) => {
  console.log("Failed:", errorInfo);
};

const App: React.FC = () => {
  const navigate = useNavigate()

  const onFinish = async (values: any) => {
    const resp = await http.post("/api/login", values);
    const { code, message, data } = resp.data;
    if(code === 200) {
      navigate('/')
      antdMessage.success(message)

      localStorage.setItem('role', data.role)
      localStorage.setItem('username', data.username)
      localStorage.setItem('token', data.token)
    } else {
      antdMessage.error(message)
    }
  
  };
  
  return (
    <Form
      name="basic"
      labelCol={{ span: 8 }}
      wrapperCol={{ span: 16 }}
      style={{ maxWidth: 600 }}
      initialValues={{ remember: true }}
      onFinish={onFinish}
      onFinishFailed={onFinishFailed}
      autoComplete="off"
    >
      <Form.Item
        label="Username"
        name="username"
        rules={[{ required: true, message: "Please input your username!" }]}
      >
        <Input />
      </Form.Item>

      <Form.Item
        label="Password"
        name="password"
        rules={[{ required: true, message: "Please input your password!" }]}
      >
        <Input.Password />
      </Form.Item>

      <Form.Item
        name="remember"
        valuePropName="checked"
        wrapperCol={{ offset: 8, span: 16 }}
      >
        <Checkbox>Remember me</Checkbox>
      </Form.Item>

      <Form.Item wrapperCol={{ offset: 8, span: 16 }}>
        <Button type="primary" htmlType="submit">
          Submit
        </Button>
      </Form.Item>
    </Form>
  );
};

export default App;
